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can be given as to the existence of other IPRs not referenced in SR 000 314 (or the updates on the ETSI Web server) 
which are, or may be, or may become, essential to the present document. 



Foreword 



This Technical Specification (TS) has been produced by the Special Mobile Group (SMG). 

The present document specifies the Radio Link Protocol (RLP) for data transmission over within the digital cellular 
telecommunications system. 

The contents of the present document is subject to continuing work within SMG and may change following formal SMG 
approval. Should SMG modify the contents of the present document, it will be re-released by SMG with an identifying 
change of release date and an increase in version number as follows: 

Version 6.x.y 

where: 

6 indicates GSM Phase 2+ Release 1997; 

X the second digit is incremented for all changes of substrance, i.e. technical enhancements, corrections, 
updates, etc.; 

y the third digit is incremented when editorial only changes have been incorporated in the specification. 
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Scope 



The present document specifies the Radio Link Protocol (RLP) for data transmission over the GSM PLMN. RLP covers 
the Layer 2 functionahty of the ISO OSI Reference Model (IS 7498). It is based on ideas contained in IS 3309, IS 4335 
and IS 7809 (HDLC of ISO) as well as CCITT X.25 and Q.92x (LAP-B and LAP-D of CCITT, respectively.) RLP has 
been tailored to the special needs of digital radio transmission. RLP provides to its users the OSI Data Link Service (IS 



RLP is intended for use with non-transparent data-transfer. Protocol conversion may be provided for a variety of 
protocol configurations. Those foreseen immediately are: 

Character-mode protocols using start-stop transmission (IA5); 

- X.25 LAP-B. 

For reasons of better presentation, material about protocol conversion has been placed within those Specifications 
concerned with the relevant Terminal Adaptors, i.e. GSM 07.02 for the asynchronous case and GSM 07.03 for the 
synchronous case. Care must be taken that that material also applies to Interworking Functions; see GSM 09.04 - 09.07. 



References 
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number. 

• For this Release 1997 document, references to GSM documents are for Release 1997 versions (version 6.x.y). 
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Functions (TAF) for services using asynchronous bearer capabilities". 
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(TAF) for services using synchronous bearer capabilities". 
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Public Land Mobile Network (PLMN) and the Circuit Switched Pubhc Data Network (CSPDN)". 
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[7] GSM 09.06: "Digital cellular telecommunication system (Phase 2+); Interworking between a 

Public Land Mobile Network (PLMN) and a Packet Switched Public Data Network/Integrated 
Services Digital Network (PSPDN/ISDN) for the support of packet switched data transmission 

services". 
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[8] GSM 09.07: "Digital cellular telecommunications system (Phase 2+); General requirements on 

interworking between the Public Land Mobile Network (PLMN) and the Integrated Services 
Digital Network (ISDN) or Public Switched Telephone Network (PSTN)". 

[9] CCITT Recommendation 1.440 (Redbook): "ISDN user-network interface data link layer - General 

aspects". 

[10] CCITT Recommendation 1.441 (Redbook): "ISDN user-network interface, data link". 

[11] CCITT Recommendation Q.920 (Redbook): "ISDN user-network interface data link layer - 

General aspects". 

[12] CCITT Recommendation Q.921 (Redbook): "ISDN user-network interface - data Unk". 

[13] CCITT Recommendation Q.921bis: "Abstract test suites for LAPD conformance tests". 

[14] CCITT Recommendation Q.922: "ISDN data link layer specification for frame mode bearer 

services". 

[15] CCITT Recommendation V.42bis: "Data Compression for Data Circuit Terminating Equipment 

(DCE) using Error Correction Procedures". 

[16] CCITT Recommendation X.25 (Redbook): "Interface between Data Terminal Equipment (DTE) 

and Data Circuit Terminating Equipment (DCE) for terminals operating in Packet Mode and 
connected to Public Data Networks by dedicated Circuit". 

[17] ISO/IEC Recommendation 4335: "Information technology - Telecommunications and information 
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procedures". 

[18] ISO Recommendation 3309: "Information technology - Telecommunications and information 

exchange between systems - High level data link control (HDLC) procedures - Frame structure". 

[19] ISO Recommendation 7498: "Information processing systems - Open Systems Interconnection - 
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[20] ISO Recommendation 8885: "Information technology - Telecommunication and information 

exchange between systems - High-level data link control (HDLC) procedures - General purpose 
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[21] ISO Recommendation 8886: "Information technology - Telecommunication and information 

exchange between systems - Data link service definitions for Open Systems interconnection". 

[22] ISO Recommendation 8509: "Information processing systems - Open Systems Interconnection - 
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procedures". 

[24] ISO Recommendation 7776: "Information processing systems - High-level data link control 

procedures - Description of the X.25 LAPB -compatible DTE data link procedures". 

2.1 Definitions and abbreviations 

Abbreviations used in the present document are listed in GSM 01.04 [1]. 

For the purposes of the present document, the following terms and definitions apply. 

backwards compatibility: RLP defines several backwards-compatible versions. That means that a newer version can 
interwork with an older one without changing the older one. This is realized by a fall back mechanism during XID 
exchange. 
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command: An instruction represented in the RLP header, causing the receiving RLP entity to execute a specific 
function. 

frame check sequence: A field of redundant information based on a cycHc code, used for error detection. 

I + S frame: An RLP frame that is used for user information transfer, carrying supervisory information piggyback. 

improper frame: An RLP frame having an FCS error or having a header the contents of which is inconsistent with this 
Specification. 

non-transparent: In PLMN data transmission, a configuration where at layer 2, protocol information of the fixed 
network is mapped on RLP elements, and vice versa. 

piggybacking: Means by which one and the same frame can carry both user information and RLP related supervisory 
information. 

response: A reply represented in the RLP-header, by which the sending RLP entity reports back about its status. 

RLP frame: A sequence of contiguous bits, representing an RLP procedural element. 

RLP header: That part of an RLP frame that encodes either a command or a response, located at the beginning of the 
RLP frame. 

S frame: An RLP frame that contains supervisory information in the absence of user information. 

transparent: In PLMN data transmission, a configuration where at layer 2 (and also at the layers above) no protocol 
conversion takes place. 

U frame: An RLP frame that contains unnumbered protocol control information. 



3 Introduction 

Three versions of RLP are defined: 

RLP version 0: single-link basic version; 

RLP version 1: single-link extended version (e.g. extended by data compression); 

RLP version 2: multi-link version. 

RLP uses one (single-link) or from 1 up to 4 (multi-link) physical links. However, the RLP multi-link version is 
designed to be able to support up to 8 physical links. If, in the call setup signalling, either end indicates that it cannot 
support multilink operation, neither end shall require usage of RLP -versions higher than 1 . If the BC negotiation during 
call setup results in a possibility for multi-link operation during the call, both ends shall require and accept RLP version 
2 only. 

If the BC negotiation during call setup results in maximum number of traffic channels = 1 TCH and UIMI = not 
required/not allowed or up to 1 TCH/F allowed/may be requested, this is interpreted as if at least one end does not 
support multilink operation, and neither end shall require RLP version higher than 1 . 

RLP makes use of an underlying FEC (Forward Error Correction) mechanism. For RLP to perform adequately it is 
assumed that the basic radio channel together with FEC provides for a block error rate of less than 10 %, where a block 
consists of 240 or 576 bits (Further study on the BLER for 576-bit blocks is needed). Furthermore, it is assumed that in 
case of multi-link RLP the difference of the delay between all physical links is less than timer T4. 

RLP frames are sent in strict alignment with the radio transmission. (For details, see GSM 04.21). RLP frames are of a 
fixed size of 240 (TCH/F9.6 channel coding) or 576 bits (TCH/F14.4 channel coding). Whenever a frame is to be sent, 
the RLP entity has to provide the necessary protocol information to be contained in it. Provision is made for 
discontinuous transmission (DTX). 

RLP spans from the Mobile Station (MS) to the interworking function (IWF), located at the nearest Mobile Switching 
Centre (MSC), or beyond. Depending on the exact location of the IWF, handover of the MS may result in link-reset or 
even total loss of the connection. 
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The MS shall initiate the RLP link. In addition the MSC/IWF may initiate the RLP hnk. 

In the terminology of HDLC, RLP is used in a balanced configuration, employing asynchronous operation, i.e. either 
station has the right to set-up, reset, or disconnect a link at any time. Procedural means are provided for to deal with 
contentious situations, should they ever occur. 

RLP is full-duplex in the sense that it allows for information to be transferred in both directions simultaneously. 



Frame structure 



4.1 



Basic frame structure 



An RLP-frame has a fixed length of either 240 or 576 bits consisting of a header, an information field, and an FCS 
(frame check sequence) field. The size of the components depends on the the radio channel type, RLP version and on 
the RLP frame. As a benefit of using strict alignment with underlying radio transmission there is no need for frame 
delimiters (like flags etc.) in RLP. In consequence, there is no "bit-stuffing" necessary in order to achieve code 
transparency. Frames cannot be aborted while being transmitted. 

a) 240 bit frame size 



version and 1, version 2 (U frames only) 
version 2 (S and l+S frames only) 



Header 


Information 


FCS 



16 bit 
24 bit 



200 bit 
192 bit 



24 bit 
24 bit 



Header 


Information 


FCS 



b) 576 bit frame size 



version 0, 1, and version 2 (U frames only) 16 bit 536 bit 

version 2 (S and Ih-S frames only) 24 bit 528 bit 

Figure 1 : Frame structure 



24 bit 
24 bit 



4.2 



RLP header 



An RLP-header carries one of three types of control information, the first being unnumbered protocol control 
information (U frames), the second being supervisory information (S frames), the third being user information carrying 
supervisory information piggybacked (Ih-S frames). 



4.3 



Order of transmission 



The header, as defined in clause 5.2, shall be transmitted from left to right. The FCS shall be transmitted commencing 
with the highest order term. The order of bit transmission for the information field is from left to right. 

4.4 Frame check sequence 

The FCS shall be the ones complement of the modulo 2 sum of: 
a) the remainder of: 

For 9.6/4.8 kbit/s channel coding: 
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X216(x23 + x22 + x21+x20 + xl9 + xl8 + xl7 + xl6 + xl5 + xl4 + xl3 + xl2 + xll+xl0 + x9 + x8 + x7 + x6 + x5 + x4 + 

x^ + x2 + x+ 1) 

For 14.4kbit/s channel coding: 

jj^552 (-jj^23 + y22 + ^^^21 + ^^^20 + ^^19 + ^^18 + ^^17 + ^^^16 + ^^15 + ^^14 + ^^^13 + ^^12 + ^^11+ ^^10 + ^9 + x^ + x"^ + x^ + x^ 
+ x^ + x-^ + x^ + X + 1 

divided modulo 2 by the generator polynomial: 

x24 + x23 + x2l + x2*' + x^^ + x'"^ + x^^ + x'^ + x^^ + x*^ + x'' + x^ + x^ + x2 + 1 
and 

b) the remainder of the division modulo 2 by the generator polynomial: 

x2^ + x23 + x2l + x2*' + x^^ + x'"^ + x^^ + x'^ + x^^ + x*^ + x'' + x^ + x^ + x2 + 1 

of the product of x24 by the content of the frame, excluding the FCS field. (The first bit transmitted corresponds 
to the highest order term.) 

Implementation note: As a typical implementation, at the transmitter, the initial content of the register of the device 
computing the remainder of the division is pre-set to all ones and is then modified by division by the generator 
polynomial (as described above) of the header and information field; the ones complement of the resulting remainder is 
transmitted as the 24 bit FCS sequence. 

At the receiver, the initial content of the register of the device computing the remainder is pre-set to all ones. The final 
remainder after multiplication by x24 and then division (modulo 2) by the generator polynomial: 

x2'* + x23 + x2l + x2*' + x^^ + x'"^ + x^^ + x'^ + x^^ + x*^ + x'' + x^ + x^ + x2 + 1 

of the serial incoming protected bits and the FCS will be: 

011011011000100100110000 (x23 to xO, resp.) 

in the absence of transmission errors. 



Elements and procedure 



5.1 Modes 

An RLP entity can be in one of two modes: 

Asynchronous Balanced Mode (ABM) 
Asynchronous Disconnected Mode (ADM) 

5.1 .1 Asynchronous Balanced Mode (ABM) 

In ABM, which is the data link operational mode, either RLP entity may send commands at any time and may initiate 
response frame transmission without receiving explicit permission to do so from the other RLP-station. In ABM, frames 
shall be used for information field transfer and/or to indicate status changes in the RLP-station. 

5.1.2 Asynchronous Disconnected Mode (ADM) 

In ADM, which is the data-link non-operational mode, the RLP entity shall be logically disconnected from the data link 
and shall, therefore, neither transmit nor accept numbered information frames. 
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The RLP entity shall, however, be permitted to transmit and accept NULL, DM, UI, TEST and XID frames. Either RLP 
entity can issue an SABM command at any time, in order to terminate the ADM state. In that case, entrance of the ABM 
state will be indicated by a UA response from the opposite station. If the opposite station is not able to enter ABM, it 
will indicate this by a DM response. All commands other than those mentioned above and any unsolicited response will 
be ignored in ADM under all circumstances. 

5.2 Header and parameters 

The formats defined for the header are listed in figure 2. 

5.2.1 Generally usecJ bits 

NOTES: C/R = COMMAND/RESPONSE BIT 
P/F = POLL/FINAL BIT 
X = DON'T CARES 
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Version 2: 

NOTES: S = L2R Status Bit 

N(S) : Bit I low order bit 

N(R) : Bit 14 low order bit 
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Figure 2: l-ieader formats 



5.2.1.1 



Command/response bit, C/R 



The C/R-bit is used to indicate whether the frame is a command or response frame and whether the P/F-bit is to be 
interpreted as a poll or final bit, resp. For commands, the C/R bit shall be set to " 1 ", for responses it shall be set to "0" . 
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5.2.1.2 Poll/Final bit, P/F 

The P/F-bit is used to mark a special instance of command/response exchange. With a command, it is called the P-bit, 
with a response, it is called the F-bit. In any one direction, only one P/F-bit exchange may be outstanding at any time. A 
response with the F-bit set to " 1 " shall always reflect the latest receive status of the RLP entity. 

A P/F-bit exchange always starts with a command frame with the P-bit set to "1", which shall be answered by a response 
frame with the F-bit set to " 1 " at the earliest response opportunity. 

No unsolicited F-bit = "1" is allowed. Such a frame shall be considered "improper" (see subclause 5.3.1). In ABM, the 
use of the P/F-bit with numbered information exchange is only allowed for checkpoint-recovery (see subclause 5.3.3). 

5.2.2 Unnumbered frames, U 

5.2.2.1 Set asynchronous balanced mode SABM (1 1 1 00) 

The SABM encoding is used as a command only. It is always used with the P-bit set to "1". 

The SABM command is used either to initiate a link for numbered information transfer, i.e. to go from ADM to ABM, 
or to reset a link already established for numbered information transfer. With an SABM command, no information 
transfer is allowed. 

When issuing an SABM, the RLP entity has set to zero its internal variables for sending and receiving numbered 
information. The other RLP entity, on receiving an SABM command, will either confirm it by setting to zero its internal 
variables for sending and receiving numbered information and then issuing an UA (unnumbered acknowledgement) 
response or reject it by sending a DM (disconnected mode) response. In the former case, both entities have entered 
ABM and numbered information transfer may commence. In the latter case, both entities are in ADM. 

When an SABM command is issued, a loss of information may occur. Appropriate action is in the responsibility of the 
layers above. 

5.2.2.2 Unnumbered Acknowledge. UA (001 1 0) 

The UA encoding is used as a response only. It is used to positively acknowledge an SABM or DISC command. With 
the UA response, no information transfer is allowed. In version 2, the UA response is sent no sooner than T4 (see 
Section 5.5.6) after the last information frame sent. Information frames received within a period of T4 after reception of 
the SABM are discarded. 

5.2.2.3 Disconnect, DISC (00010) 

The DISC encoding is used as a command only. It is used to disestablish a link, previously established for numbered 
information transfer, i.e. to terminate ABM and go into ADM. With the DISC command, no information transfer is 
allowed. 

The other RLP-entity shall answer with a UA response before actioning the DISC command. When a DISC command is 
actioned, loss of information may occur. It is the responsibility of the layers above, to provide for a "graceful" 
disconnect. 

5.2.2.4 Disconnected Mode, DM (1 1 000) 

The DM encoding is used as a response only. It is used by RLP entity to report that it is in ADM and, as an answer to 
SABM, that it is (possibly temporary) unable to action a mode setting command. With the DM response, no information 
transfer is allowed. 

5.2.2.5 Unnumbered Information, Ul (00000) 

The information field is to be interpreted as unnumbered information. Unnumbered Information (UI) frames can be sent 
in both ADM and ABM. There is no acknowledgement of receipt of Ul-frames within RLP. 
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5.2.2.6 



Exchange Identification, XID (11101) 



The information field is to be interpreted as exchange identification. This frame is used to negotiate and renegotiate 
parameters of RLP and layer 2 Relay function. XID frames can be sent in both ADM and ABM. 

The negotiation procedure is one step i.e. one side will start the process by sending an XID command, offering a certain 
set of parameters from the applicable parameter repertoire (see table 1) the sending entity wants to negotiate proposing 
values within the allowed range. In return, the other side will send an XID response, either confirming these parameter 
values by returning the requested values, or offering higher or lower ones in their place (see table 1 for sense of 
negotiation), except when the indicated RLP version is a lower one where a limited set of those parameters presented in 
the XID command may be answered according to the negotiated version. In RLP versions higher than "0", any 
unrecognisable parameters will be ignored. Default values will apply to those parameters which are not commented upon 
by the responding side (see section 5.4 for default values). This normally will end the negotiation process. XID frames 
are always used with the P/F-bit set to "1". 

Without any prior XID exchange, default values will apply (see section 5.4). A negotiation of data compression 
parameters (see table 1) is only allowed in ADM. In addition, in RLP version 2, negotiation of RLP version N°(see 
table 1) is only allowed in ADM. 

In the case of a collision of XID commands, all XID commands shall be ignored. The MS shall restart the parameter 
negotiation on expiry of Tl, while the Interworking Function shall do so on expiry of twice the value of TL An 
unsuccessful XID exchange shall be repeated on expiry of TL After N2 times of unsuccessful repetition, the link shall 
be disconnected. 

In table 1 a list of parameters is given which constitute the parameter repertoire. In addition, the format of the XID 
information field is given. 

Table 1 : XID parameters 



Parameter Name 


Type 


Length 


Format 

(87654321) 


Units 


Sense of 
Negotiation 


Valid in 
Versions 


RLP version N° 


1 




bbbbbbbb* 


./. 


down 


>0 


IWF to MS window size 


2 




OObbbbbb 


./. 


down 


0..1 


IWF to MS window size 


2 




OObbbbbb 


8 


down 


>2 


MS to IWF window size 


3 




OObbbbbb 


./. 


down 


0..1 


MS to IWF window size 


3 




OObbbbbb 


8 


down 


>2 


Acknowledgement Timer(Tl) 


4 




bbbbbbbb 


10ms 


up 


>0 


Retransmission attempts (N2) 


5 




bbbbbbbb 


./. 


up 


>0 


Reply delay (T2) ** 


6 




bbbbbbbb 


10ms 


up 


>0 


Compression Pj 

Po 

Pj low 
Pi high 

P2 


7 


4 


aaaa 

OObb 
cccccccc 
cccccccc 
dddddddd 




none 

see [15] 

down 
down 


> 1 


Re-sequencing timer (T4) ** 


8 


1 


bbbbbbbb 


10 ms 


up 


>2 



* NOTE 1: Characters "a", "b", "c" and "d" indicate a bit which is part of the parameter value in question. 
Parameters indicated by "a" are not negotiable. 

** NOTE 2: In case of negotiation of this parameter it may be necessary to negotiate also the other timer values 
(e.g. "Acknowledgement timer" (Tl)). 

The type and length are encoded within one octet, the type field occupying bits 8 to 5 and the length field occupying bits 
4 to 1; 1 resp. 5 being the least significant bit. The least significant bit shall always be transmitted first. 

A parameter item consists of the type/length-octet followed by the value of that parameter, where the length-indicator 
gives the number of octets the value actually occupies. Such parameter items may be arranged in arbitrary order, with 
the exception of the RLP version number, which shall be sent first in RLP versions higher than "0". The parameter items 
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must begin in the first octet of the XID-information field and follow on contiguously. The parameter list is delimited by 
parameter type zero. 

5.2.2.7 Test, TEST (00111) 

The information field of that frame is to be interpreted as test information. Test frames can be sent in both ADM and 
ABM. A test sequence is always initiated by sending a TEST command in one direction and completed by sending a 
TEST response in the other direction. 

5.2.2.8 Null information, NULL (11110) 

In ADM, null-frames shall be sent each time there is a send opportunity but no UI, TEST or XID frame is awaiting 
transmission. 

In ABM, null-frames shall be sent in reset state if there is a send opportunity and no unnumbered frames are to be sent. 

The information field is to be interpreted as null information i.e. the information field is not used and its contents may be 
arbitrary. 

5.2.2.9 REMAP (10001) 

A REMAP -exchange can only take place in ABM following a change of channel coding. REMAP frames are always 
used with the P/F-bit set to "0". The exchange is started by the mobile-end which sends a REMAP command U-frame in 
the information field of which the RLP -entity indicates the N(R) of the frame - according to the 'old' frame format - 
from which the network-end should resend the information mapped into a frame format corresponding to the new 
channel coding. The mobile-end sends a REMAP -frame on every sending opportunity until a responding REMAP-frame 
is received from the network-end. The network-end answers by sending a REMAP U-frame with the C/R-bit set to 
'Response' . In the information-field the network-end indicates the N(R)-number of the frame from which the mobile-end 
should remap the information into the new frame format The network-end responds to all REMAP -commands it receives 
as long as it is in the REMAP synchronisation state. The network sends a numbered S frame with poll bit P=l or an Ih-S 
frame after the first REMAP frame to the mobile station to compel it to acknowledge the end of the REMAP condition. 
This frame is guarded by Tl. Upon reception of an Ih-S frame or an S frame with the final bit F=l from the MS, the 
IWF exists the REMAP synchronisation state. Any REMAP-acknowledgement that may arrive at the mobile-end after 
one of them has been received is discarded by the mobile-end. The RLP shall supervise the synchronisation state by a 
timer with the value of N2*T1. If the network-end does not receive an appropriate U-frame within N2*T1, it enters 
ADM. If the mobile-end does not receive a response within N2xTl measured from the transmission of the first 
command, it enters ADM. 

In addition to the N(R)-information the REMAP-frame information field can include any XID-parameters that should be 
renegotiated because of the change of channel coding. The procedures concerning these XID-parameters are as defined 
in section 5.2.2.6 (Exchange Identification) except that the mobile-end always starts the negotiation. Also the mapping 
of the parameters is as defined in section 5.2.2.6 (Exchange Identification) except that the first two octets in the REMAP 
information field are occupied by the N(R)-number (The LSB is transmitted first). The information field shall always 
include parameter type zero, which delimits the XID-parameter list. 

After the change of channel coding, default values according to the new channel coding apply until new values have 
been negotiated by the REMAP or XID procedure. Default values according to the new channel coding also apply for 
those XID parameters that are not included in the REMAP information field. Values for XID parameters whose 
negotiation is only allowed in ADM remain valid after change of channel coding. 



1 Header 1 6 bits 


1 N(R) 6 bits 1 xxxxxxxxxx | XID parameters | 


00000000 


1 xxxxxx 1 


PCS 24 bits 1 




^ Information field eitlier 200 or 536 bits x= don't care 








a.) version and 1 










Header 16 bits 


N(R) 9 bits xxxxxxx XID parameters 


00000000 


xxxxxx 


PCS 24 bits 



^ Information field either 200 or 536 bits x= don't care 
b.) version 2 



Figure 3: REIVIAP U-frame format 
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5.2.3 Supervisory frames, S, an6 numberecd information transfer ar\6 
supervisory frames combined, l+S 

In ABM, there are cases where there is no user information pending transmission. In consequence, supervisory (S) 
frames alone must be conveyed. In such cases, the information field is to be interpreted as null information, i.e. the 
information field is not used and may be of arbitrary contents. 

For reasons of optimization in the special situation of digital radio transmission, numbered information transfer frames 
carry also supervisory type information ("piggy-backing"). Numbered information can be exchanged only in ABM. 

NOTE: The extent to which piggy-backing is used by the sending RLP entity is optional. An RLP entity receiving 
any of allowed piggy-backed formats, however, shall take the appropriate actions. Implementers should be 
aware that not using the full capability of piggy-backing could, in certain circumstances, result in a less 
than optimal performance. 

5.2.3.1 Numbering 

Each I frame is sequentially numbered and may have the value through M-1, where M is the modulus. The modulus M 
is 62 (single-link) or 496 (multi-link). 

5.2.3.2 Send Sequence number, N(S) 

The send sequence number contains the number of the I frame. With the exception of SREJ conditions, information 
frames are transmitted in numerical order of their N(S). If multiple physical links are used, the frames may arrive the 
receiver in another order. Normal information transfer is halted, when the number of outstanding, unacknowledged 
frames is equal to the currently established window size (see section 5.4). 

5.2.3.3 Receive sequence number, N(R) 

The N(R) field is used in ABM to designate the next information frame to be sent by the other RLP entity and to confirm 
that all frames up to and including N(R) - 1 have been received properly. As an exception to this, in the case of SREJ 
(selective reject), N(R) designates the information frame that is selectively rejected and thus requested for 
retransmission. In this case, no previously received frames are confirmed. 

5.2.3.4 L2R Status bit 

The L2R status bit set to „1" indicates that the L2R PDU transported in the information field of the RLP PDU contains 
at least a status octet. Otherwise, the L2R PDU contains only user data. The bit is only used for RLP -version 2. 

5.2.3.5 Receive ready, RR (00) 

The RR encoding can be used either as command or response. In ABM, it is used by an RLP entity to confirm all 
information frames up to and including N(R)-1. In doing so, the RLP-station allows the other station to transmit up to k 
additional information frames, counting from N(R) onwards. The issue of an RR command/response clears any previous 
busy condition in that direction. 

5.2.3.6 Reject, RE J (01) 

The REJ encoding can be used either as command or response. It is used by an RLP entity to indicate that in numbered 
information transfer one or more out-of sequence frames have been received. Frames up to and including N(R)-1 have 
been received correctly, frames N(R) and following are requested to be retransmitted. Following retransmission of those 
frames, further frames awaiting initial transmission may be sent. With respect to each direction of transmission, only one 
REJ condition may exist at any given time. 
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A REJ condition is cleared: 

on receipt of the frame numbered N(R); 
on time-out; 

- or on reset (SABM). 

An REJ shall be sent at the earliest opportunity. On time-out, REJ frames shall not be repeated. An RLP-entity receiving 
an REJ frame with the same N(R), which has already been the starting frame of a retransmission sequence due to P/F-bit 
checkpointing, shall inhibit the retransmission due to that particular REJ frame. 

5.2.3.7 Receive not ready, RNR (1 0) 

The RNR encoding can be used either as command or response. It is used by an RLP entity to indicate that it is 
temporarily not ready to receive numbered information frames. In that case, the RLP entity is said to be in the busy 
condition. All frames up to and including N(R)-1 shall be considered acknowledged. Subsequent frames, if any, shall not 
be considered confirmed. The acceptance status of those is a matter of further status exchange. 

5.2.3.8 Selective reject, SREJ (1 1 ) 

The SREJ encoding can be used either as command or response. The SREJ command/response is used to request 
retransmission of a single frame, thus, under certain circumstances, providing for more efficient error recovery than by 
REJ. No acknowledgement of received I frames is indicated by an SREJ frame, thus allowing an RLP entity to transmit 
one or more SREJ frames with a different N(R) before earlier SREJ conditions have been cleared. 

An SREJ condition shall be cleared: 

on receipt of an information frame with N(S) equal N(R) of the SREJ; 

on time out; 

- on reset (SABM). 

No SREJ shall be issued during a pending REJ condition. For each frame, only one SREJ condition may exist at any 
time. 

SREJ frames shall be sent at the earliest possibility. On time-out, SREJ frames may be repeated. 

NOTE: Sending SREJ commands/responses is not mandatory. 

5.3 Error Recovery 
5.3.1 Improper frames 

Frames containing an FCS error or having a control field the contents of which is not implemented or inconsistent with 
those defined in this Specification are called improper frames. Improper frames shall be ignored, i.e. the receiving RLP 
station shall not make any use of their contents. 



5.3.2 N(S) sequence error 



In numbered information transfer, any information frame with an N(S) out of the normal sequence shall lead to an N(S) 
sequence error condition, unless that frame is requested for retransmission by an SREJ, sent at an earlier time. In case 
multiple channels make up a connection when the multi-link version is used the received frames must be re-sequenced. 
For that a timer T4 defines a re-sequencing period (see section 5.4) during which frames may be out-of-order. An N(S) 
sequence error condition only occurs if the N(S) arrives after the expiry of T4. There are three mechanisms to deal with 
N(S) sequence errors: 
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REJ recovery; 

SREJ recovery; 

P/F-bit recovery (checkpointing); 

the first two being the responsibility of the receiving station, the last being the responsibility of the sending station. 
There are no strict rules as to whether REJ or SREJ recovery shall be applied, however, if a station decides to initiate 
REJ or SREJ recovery, it shall do so at the earliest opportunity. The information part of out-of sequence frames shall be 
discarded, unless the receiving station intends to initiate SREJ recovery. 

5.3.3 N(R) error 

Any confirming N(R) that is not in the range of the window size shall be ignored. 

5.3.4 Time-out ar\6 checkpointing 

All frames requiring a response or acknowledgement shall be guarded by time-out (timer Tl). In detail, those frames 
are: 

- SABM; 

- DISC; 

- REJ; 

- SREJ; 

numbered information frames (see note); 
any frame with the P-bit set to "1" in ABM, i.e. checkpointing. 
NOTE: Tl started, or restarted if already running, on the transmission of every numbered information frame. 

5.3.4.1 Treatment of errors during link establishment, link reset and link disconnect 

An SABM, which is not answered by either UA or DM within the timer period, shall be repeated up to N2 times. 

A DISC, which is not answered by UA within the timer period, shall be repeated up to N2 times. 

If the SABM or DISC, respectively, is finally unanswered, the RLP station will go into ADM in any case. For this 
reason, it is the responsibility of the management of any RLP entity to put the RLP entity into ADM, should there be an 
indication of a permanent outage, i.e. a loss of connectivity longer than N2 times the timer value. 

5.3.4.2 Treatment of errors during numbered information transfer 

The last frame of a sequence of numbered information frames shall also be guarded by time-out. If neither a positive 
acknowledgement nor a REJ is received, the RLP entity will start checkpoint recovery, i.e. the station will send a frame 
with the P-bit set to "1", requesting the latest status information from the other entity, indicated by the F-bit set to "1". In 
that case, status information is carried either by RR or RNR responses and all frames currently held by the responding 
RLP entity which are not delivered because of missing frames shall be discarded. A P-bit set to " 1 " shall only be sent 
with a Supervisory Frame. 

Awaiting the latest status information from the other RLP entity, the sending entity does not react on REJ and SREJ 
frames received during this time. If such status information is received, retransmission from N(R) onwards will be 
performed if appropriate. However, no frame sequence starting with a given N(R) shall be retransmitted more than N2 
times. If there is a frame sequence that cannot be transmitted successfully after N2 repetitions, the RLP link shall be 
reset or disconnected. 

If no status information is received during the time-out period, this request will be repeated up to N2 times. If still there 
is no valid status reported back, the RLP link shall be reset or disconnected. 
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5.3.5 Contentious situations 

Due to the asynchronous procedure, various contentious situations may arise. A contention of SABMs shall result into 
both entities be set into ABM or be reset. A contention of DISC'S shall result into both entities be disconnected. A 
contention of SABM and DISC shall result into both entities be disconnected. 

5.4 Transitions between TCH/F9.6 and TCH/F1 4.4 channel 
codings 

The RLP has to change the supported frame length due to transitions between different channel codings. The RLP 
entities have to be re-synchronised after a change of the channel coding. 

Any change of the channel coding is indicated to the RLP- entity by an external event. The RLP-entity at the mobile-end 
enters the synchronisation state when it receives a relevant Radio Resource Management message, and it starts sending 
the REMAP -messages at the earliest possible time. The RLP-entity at the network-end enters the synchronisation state 
when the network-end detects Layer 1 synchronisation after a change of channel coding. The change of channel coding 
is eventually confirmed by an outband signalling message. 

On entering the synchronisation state timers are halted and zeroed, and the TX- and RX-windows are frozen. When the 
RLP entity enters the synchronisation state it clears all SREJ or REJ conditions, discards all out-of-sequence frames 
received and clears all previous re-transmission requests received by any SREJ. 

After this the mobile-end starts a REMAP -exchange (Section 5.2.2.9). When an RLP-entity receives a REMAP-frame, it 
moves the user information contained by the frames to be remapped from the TX-window to a transition buffer between 
the RLP- and L2R-entities. The L2R uses the information in this buffer before mapping new data into the PDUs. The 
network-end regards the REMAP -procedure as completed when it has received an I-nS-frame, an S-frame or an SABM 
U-frame from the mobile-end, whereas the mobile-end leaves the synchronisation state after receiving a responding 
REMAP-frame or an SABM U-frame. The data in the transition buffer at the network-end must not be deleted before an 
Ih-S-, or an S-frame is received from the mobile-end. 

Supervisory or Information transfer frames or XID U frames are discarded by the receiving entity while in REMAP 
synchronisation state. If the RLP entity receives another U-frame, it reacts according to the defined procedures. That is, 
if the frame is an SABM frame it performs a reset procedure and leaves the synchronisation state. If the frame is NULL, 
UI or TEST frame, RLP performs the defined procedure and remains in the synchronisation state. In the case of a DISC 
frame RLP terminates ABM and goes into ADM. 

After the REMAP-procedure is completed, the RLP-entities leave the synchronisation state and normal operation is 
resumed. On resuming the normal operation, the TX- and RX- windows are emptied. The N(S)-numbering resumes from 
the value indicated in the REMAP-message by the N(R)-number. 

Abortion of the transition or another transition taking place during the REMAP-procedure restarts the REMAP- 
procedure in order to resume operation using the channel coding corresponding to the latest transition. 
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5.5 List of system parameters 



The system parameters are as follows: 



Table 2: RLP parameter values 



Name 


Range of values 


Default value 


Recommended value 


Version N° 


0-2 





2 


k MS ^ IWF 
(for N° = 0/1) 


0-61 


61 


61 


k MS => IWF 
(for N° = 2) 


- kmax (note 3) 


480 


240 (note 2) 


k IWF ^ MS 
(forN° = 0/l) 


0-61 


61 


61 


k IWF ^ MS 
(for N° = 2) 


- k^^ (note 3) 


480 


240 (note 2) 


Tl (note 1) 


> 420 ms (version2) 

> 380 ms 

> 440 ms 

> 600 ms 


520 ms (fullrate on 14.5 kbit/s) 

480 ms (fullrate on 12 kbit/s) 
540 ms (fullrate on 6 kbit/s) 
780 ms (halfrate) 


520 ms (fullrate on 14.5 kbit/s) 
480 ms (fulb-ate on 12 kbit/s) 
540 ms (fullrate on 6 kbit/s) 
780 ms (halfrate) 


T2 (note 1) 




< 80 ms (fullrate on 14.5 kbit/s) 

< 80 ms (fulrate on 12 kbit/s) 

< 80 ms (fullrate on 6 kbit/s) 

< 80 ms (halfrate) 


< 80 ms (fullrate on 14.5 kbit/s) 

< 80 ms (fulb-ate on 12 kbit/s) 

< 80 ms (fullrate on 6 kbit/s) 

< 80 ms (halfrate) 


N2 


>0 


6 


6 


Pt 











Po 


0-3 





3 


Pi 


512-65535 


512 


2048 


P2 


6-250 


6 


20 


T4 (note 1) 


>25ms 


30 ms 

50 ms (fullrate on 14.5 kbit/s) 


30 ms 

50 ms (fullrate on 14.5 kbit/s) 



NOTE 1 : The timer values shall fulfil the formula: 

Tl > T2 H- T4 H- (2 * transmission delay) for multi-link operation 
Tl > T2 H- (2 * transmission delay) for single link operation 

NOTE 2: This value is recommended in the case of 4 physical links. 

NOTE 3: The maximum window size shall fulfil the formula 

kmax < 496 -n*(lH-T4/20 ms), where n denotes the number of channels. 
Any value k within the given range may be chosen. 
However, to avoid transmission delay the value k should be 
k > n * (2 * transmission delay) / 20 ms. 

5.5.1 RLP Version N° 

The current version of RLP is "2". "0" is the default value for the version N°. RLP-versions are backwards compatible. 
It is assumed that future versions of RLP will be backwards-compatible with former ones. Backwards-compatible refers 
to the signalling, i.e. the handling of the parameters in the XID frame. The parameters are defined as specified by the 
RLP version with the lower number. 

5.5.2 IVIaximum number of outstanding I frames k (Window size) 

The window size is the maximum number (k) of sequentially numbered I frames that may be outstanding (i.e. 
unacknowledged) at any given time. It shall be agreed for a period of time. 
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In case of a single-link version the value can never exceed 61. In the case of a multi-link version it is necessary to use a 
window size that is less than the sequence number space to avoid misinterpretations of the confirming N(R). Therefore, 
a guard section is defined and the value k must not exceed the value k^ax defined in table 2. On mutual agreement 
between the communication parties, a smaller window size may be established. For the support of 4 physical links, a 
value of 240 is recommended. 

5.5.3 Timer T1 

The period of Timer Tl is regarded to start at the beginning of the transmission of the relevant frame. 

The negotiation (or default) value is defined to be the earliest instant to enter recovery. 

The period of Timer Tl at the end of which retransmission of a frame may be initiated according to the procedures 
described in 5.3 above, is a system parameter agreed for a period of time. 

The proper operation of the procedure requires that Timer Tl be greater than the maximum time between transmission 
of frames (S ABM, DM, DISC, I or supervisory commands) and the reception of the corresponding frame returned as a 
response to this frame (UA, DM or acknowledging frame). Therefore, the RLP entity should not delay the response or 
acknowledging frame returned to the above frame by more than a value T2. T2 is a system parameter, which is less than 
Tl . Tl is influenced by the value of T4 and shall fulfil the formula in table 2. 

5.5.4 Maximum number of retransmissions N2 

The value of the maximum number of retransmissions N2 of a frame following the running out of Timer Tl is a system 
parameter agreed for a period of time. 

5.5.5 Data Compression Parameters 

If the Layer 2 Relay function supports a data compression function and its use is desired the needed data compression 
parameters have to be negotiated. The parameter Pj is not negotiable. In case of V.42 bis the parameters Pq, Fj and F2 
have to be negotiated. The parameters are defined as follows: 

Pj. Type of data compression 

V.42 bis 

other values are reserved 
Fq: V.42bis data compression request 

compress in neither direction 

1 compress in initiator-responder direction only 

2 compress in responder-initiator direction only 

3 compress in both directions 

F^: V.42bis number of possible codewords in the algorithm 
F2: V.42bis maximum encodable data string length 
The initiator is the sender of XID command, the responder is the sender of XID response. 

5.5.6 Re-sequencing periocJ (Timer T4) 

In the case of a multi-link version frames may be received out of sequence due to different transmission delays. The 
period of timer T4 guards the re-sequencing period. During this time frames may be out of sequence. 

T4 is a system parameter agreed for a period of time. The proper operation of the procedure requires that the timer T4 
shall be greater than the re-sequencing period and it shall fullfil the formula in table 2. A change of the timer T4 has 
impact on the usable maximum window size as defined in table 2. 
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5.6 Support for discontinuous transmission (DTX) 

In both ADM and ABM, whenever the RLP entity has no numbered or unnumbered supervisory commands/responses 
and no information transfer frames pending transmission, the RLP entity shall indicate to the lower layer that the DTX 
function may be invoked. 

NOTE: In case DTX is invoked, in ADM a NULL-frame will be sent, and in ABM an RR or RNR S-frame will be 
sent. 



6.1 



Service definitions 



Introduction 



This chapter defines the service provided by the RLP-sublayer to the L2R-sublayer at the boundary between the RLP- 
sublayer and the L2R-sublayer. 

The relationships between RLP-sublayer, L2R-sublayer and RLP -protocol are shown in figure 3. 



RLP 

< > 



L2RSL 



RLPSL 



RLP Service 



provider 



Figure 4: Basic relationsliip between RLP and L2R 

The RLP service is defined in terms of: 

the primitive actions and events of the service; 

the parameters associated with each primitive action and event; 

the inter-relationship between, and the valid sequence of, these actions and events. 

6.2 Conventions 

For the description of the Data Link Service, the following conventions are used with time-sequence diagrams: 



RLP-REQUEST 



RLP-CONFIRM 



RLP-INDICATION^ 
RLP-RESPONSE 



Figure 5: Confirmed service withi acltnowledgement 



RLP-REQUEST 



RLP-INDICATIO 



> 



Figure 6: Unconfirmed service 



In time-sequence diagrams, time moves from top to bottom. Arrows indicate the flow of information. Such flow of 
information may be subject to implicit flow-control. Skewed lines indicate a logical relationship between arrows. For 
clarity, the absence of such a relation may be marked by the symbol "~" (tilde). 



£75/ 



(GSM 04.22 version 6.2.0 Release 1997) 



22 



ETSI TS 100 946 V6.2.0 (2000-01) 



6.3 Queue model 

Between the two endpoints of an RLP-connection, there exists a flow control function. As a means of specifying this 
flow control feature and its relationship with other capabilities of the RLP, the following queue model is provided. 



Service user 
A 



Service user 
B 





Access point 




Access point 








Dmompc frnm A tn R 








'' 


\. X n 4._ A 








Service provider 







Figure 7: Queue IVIodel 

The following objects may be placed in a queue by a service user: 

a) connect; 

b) connection-mode data (numbered information); 

c) reset; 

d) disconnect. 

The following objects may be placed in a queue by a service provider: 

a) reset; 

b) synchronization mark; 

c) disconnect. 

NOTE: Other possible objects (i.e. unnumbered information, identification, test) are irrelevant (-) to the queue 
model and for reasons of simplicity are not shown. 



Following 
Preceding 


Connect 


Data 


Reset 


Sync Mark 


Disconnect 


Connect 


NA 


— 




NA 


DES 


Data 


NA 


— 


DES 


NA 


DES 


Reset 


NA 


— 


DES 


— 


DES 


Synchronization Mark 


NA 


— 


DES 


NA 


DES 


Disconnect 


NA 


NA 


NA 


NA 


DES 



Legend: 

NA : Not applicable 

— : not destructive, not able to advance ahead of the preceding object 

DES : Destructive to the preceding object 
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6.4 List of Primitives 

Link establishment 

RLP-CONNECT-REQUEST 

RLP-CONNECT-INDICATION 

RLP-CONNECT-RESPONSE (-NEG) 

RLP-CONNECT-CONFIRM (-NEG) 
Normal Data Transfer 

RLP-DATA-REQUEST (S, INF) 

RLP-DATA-INDICATION (S, INF) 

NOTE: The parameter S (L2R status bit) is only relevant for RLP-version 2. 
Reset 

RLP-RESET-REQUEST 

RLP-RESET-INDICATION 

RLP-RESET-RESPONSE 

RLP-RESET-CONFIRM 
Release 

RLP-DISCONNECT-REQUEST 

RLP-DISCONNECT-INDICATION 
Miscellaneous 

unnumbered information 

RLP-UNITDATA-REQUEST (INF) 

RLP-UNITDATA-INDICATION (INF) 
Exchange Identification 

RLP-XIDDATA-REQUEST (INF) 

RLP-XIDDATA-INDICATION (INF) 
Test 

RLP-TESTDATA-REQUEST (INF) 

RLP-TESTDATA-CONFIRM (-NEG) (INF) 
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6.5 Possible RLP time sequence diagrams 

a) Connection establishment (without colUsion) 



RLP-CONNECTREQ^ 



^ 



LP-CONNECT CONF 



b) Connection estabHshment (with colHsion) 



RLP-CONNECT REQ> 



4 



LP-CONNECT CONF 



c) User invoked release (without collision) 



RLP-DISCONNECT RE 



V 



d) Collision of user invoked releases 
RLP-DISCONNECT REO 



e) Simultaneous user and provider invoked release 



RLP-DISCONNECT REO 



f) Provider invoked release 

RLP-DISCONNECT IND 



¥^ 



g) Provider rejection of establishment 



RLP-CONNECT REO 
> 

RLP-CONNECT 
• CONF-NEG 



RLP-CONNECT IN 



^ 



RLP-CONNECT RESP 




RLP-CONNECT REO 



RLP-CONNECT CONF 



QNF 



RLP-DISCONNECT IND 



INC 




RLP-DISCONNECT REO 




RLP-DISCONNECT I 



ND 




RLP-DISCONNECT I 



ND 
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h) Normal data transfer 



RLP-DATAREQ. 



RLP-DATA IND 



I) User invoked reset 



RLP-RESET REQ 



RLP-RESET CONF 




RLP-RESET IND 



RLP-RESET RESP 



j) Collision of user invoked resets 

RLP-RESET REQ 



RLP-RESET IND 




^ 



LP-RESET REQ 



RLP-RESET IND. 



k) provider invoked reset 

RLP-RESET IND 



RLP-RESET RESP 



^ 




RLP-RESET IND 



RLP-RESET RESP 



1) simultaneous user and provider invoked reset 
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RLP-RESET REQ 



RLP-RESET IND 



RLP-DISCONNECT 




RLP-DATA-REQUEST 
or INDICATION 

Figure 8: State transition diagram for sequence of RLP connection-mode service primitives 
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Annex A (informative): 
RLP SDL Diagrams 

This annex describes a model implementation of an RLP entity for RLP version "0". 

The description should help to clarify GSM Specification 04.22, the RLP service and protocol definition. 

However, it is not intended to restrict any implementation of an RLP entity in any way, on condition the implementation 
shows the correct behaviour at the RLP protocol level. 

The model implementation consists of three processes. Process "SEND_PDU" adds the CRC to a given PDU and hands 
it to the lower layer entity for transmission. Process "RECEIVE_PDU" gets a received PDU block, checks the value of 
the CRC and the bits of the PDU header. If the CRC has the right value and if the header is syntactically correct, the 
receipt event is signalled to the "RLP_KERNEL" process, which is the protocol handling automaton. 

Each process is described as an extended finite state machine (using SDL-Diagrams). 

Each state of the automaton is described by a (main-)state number and a corresponding (main-)state name. The state may 
further be distinguished by the value of other state variables. This scheme is used because not every state variable needs 
to be defined in every state. The states are defined in chapter A.l. 

The RLP machine reacts on events, which may be classified as: 

lower layer interface events; 

upper layer interface events; and 

station management or internal events. 
The events of the RLP- Kernel are described in section A.2. 



A.1 List of RLP entity states 
A.1.1 (main) states 



state number state symbol state name 






SO 


ADM and Detached 


1 


S1 


ADM and Attached 


2 


S2 


Pending Connect Request 


3 


S3 


Pending Connect Indication 


4 


S4 


ABM and Connection Established 


5 


S5 


Disconnect Initiated 


6 


S6 


Pending Reset Request 


7 


S7 


Pending Reset Indication 



A. 1.2 state variables 

The main states are further distinguished by the values of the state variables. However, not every state variable is used 
(evaluated/ defined) in every state. 

First some constants need to be defined: 

M = 62 number of different sequence numbers (modulus) 

Nmin = smallest sequence number 

Nmax = 61 largest sequence number (= M - 1) 

N2 = 6maximum number of retransmissions 
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variable name variable type and range 



semantic 



Ackn_FBit 


(0,1) 


AcknState 


(idle, send) 


C 


(0,1) 


Data 


char[25] 


DISC_Count 


(0, 1,..., N2) 


DISC_PBit 


(0,1) 


DISC_State 


(idle, send, wait) 



DM_FBit 


(0,1) 


DM_State 


(idle, send) 


DTX_SF 


(N, RR, RNR) 


DTX_VR 


(0, 1,.., Nmax) 


F 


(0,1) 


NR 


(0, 1,..., Nmax) 


NS 


(0, 1,..., Nmax) 


P 


(0,1) 


P_F 


(0,1) 


Poll_Count 


(0, 1,..., N2) 


PolLState 


(idle, send, wait) 



Poll_xchg 



(idle, wait) 



R[IV1] 


record array 


R[n].Data 


char[25] 


R[n].State 


(idle, rcvd, ackn, srej, wait) 



Value of the F-Bit used in the next acknowledging PDU. 

Ackn_State = send means, an acknowledging PDU (Supervisory 
or Data) has to be sent. 

to store the C/R-Bit value of a received S- or l-frames 

to store temporarily the information part (user data) of a received 
l-frame. 

to count the transmissions of DISC. 

The value of the P-bit in the next DISC command PDU. 

if (DISC_State = send) the DISC command PDU has to be sent at 

the next possible opportunity. 

if (DISC_State = wait) the RLP entity waits for the corresponding 

response. 

Value of the F-Bit used in the next DIVI response PDU. 

if (DM_State = send) the PDU DM has to be sent. 

to store the last Supervisory frame for DTX (only RR or RNR can 
be suppressed) 

to store the last transmitted value of VR (used to decide the DTX 
condition) 

to store temporarily the F-bit of a received response PDU. 

to store temporarily the receive sequence number of a received 
S- or l-frame 

to store temporarily the send sequence number of a received I- 
frame 

to store temporarily the P-bit of a received command PDU 

to store temporarily the P- or F-bit of received command or 
response PDUs 

to count the transmissions of poll requests 

(Poll_State = send) means, a supervisory PDU with P-bit set to 
one has to be sent 

(Poll_State = wait) means, the RLP entity waits for the response 
with F-bit set to one 

(Poll_xchg = idle) means, sending of a frame with P-bit set is 

allowed 

(Poll_xchg = wait) means, an acknowledgement of a previous P- 

bit is outstanding 

Receiver slots (M slots, numbered to M-1) 

to store user information 

(R[n]. State = rcvd) means, data has been received (with 

sequence number n). 

(R[n]. State = ackn) means, data has been received and 

acknowledged 

(R[n]. State = srej) means, the retransmission of data has to be 

requested using srej(n). 

(R[n]. State = wait) means, the entity waits for the requested 

retransmitted data 
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REJ_State 


(idle, send, wait) 


returncode 


Integer 


RRReady 


Boolean 


SABM_Count 


(0, 1,..., N2) 


SABM_State 


(idle, send, wait) 


S[M] 


record array 


S[n].Data 


char[25] 


S[n].State 


(idle, send, wait) 


SF 


(RR, RNR, REJ, SREJ) 


T 


Timer 


TEST_Count 


(0, 1,...,N2) 


TEST_C_Data 


char [25] 


TEST_C_PBit 


(0,1) 


TEST_C_State 


(idle, send, wait) 


TEST_R_Data 


char[25] 


TEST_R_FBit 


(0,1) 


TEST_R_State 


(idle, send) 


T_RCVR 


Timer 


T_RCVS(n) 


Timer 


T_TEST 


Timer 


T_XID 


Timer 


UA_FBit 


(0,1) 


UA_State 


(idle, send) 


ULData 


char[25] 


ULPBit 


(0,1) 


ULState 


(idle, send) 


VA 


(0, 1,..., Nmax) 


VD 


(0, 1, ...,Nmax) 


VR 


(0, 1, ..., Nmax) 



vs 



(0, 1, ..., Nmax) 



The REJState is send if and only if a REJ PDU has to be sent 

used in procedures to report a result 

Remote Receiver Ready 

to count the transmissions of SABIVI 

if (.._State = send) the SABIVI PDU has to be sent 

if (.._State = wait) the RLP entity waits for the UA response 

Sender Slots (M slots, numbered to IVI-1) 

user information to be sent 

(S[n]. State = send) means, data has to be sent 
(with sequence* n). 

to store the last superv. PDU type 

used by the data sender if waiting for l-frame acknowledgements 
or F-bits 

to count the transmissions of TEST 

data to be sent in the next TEST command PDU 

value of the P-Bit used in the next TEST command PDU 

if (.._State = send) the TEST command PDU has to be sent 
if (.._State = wait) the RLP entity waits for the next TEST 
response 

data to be sent in the next TEST response PDU 

value of the P-Bit used in the next TEST response PDU 

if (.._State = send) the TEST response PDU has to be sent 

used by the receiver to timeout a REJ condition 

used by the receiver to timeout a SREJ condition for Slot n 

used by the sender of a TEST frame if waiting for a TEST 
response 

used by the sender of a XID frame if waiting for the XID response 

value of the F-Bit used in the next UA response 

if (UA_State = send) an UA PDU has to be sent 

data to be sent in the next Ul PDU 

value of the P-Bit used in the next Ul PDU 

if (ULState = send) a Ul PDU has to be sent 

frame sequence number of oldest not yet acknowledged 

l-frame 

(if VA = VS then there are no unacknowledged frames) 

slot number used in the next Data_Req 

receiver sequence number (the next received l-frame is expected 
to carry this sequence number) 

sender sequence number (under normal operating conditions the 
next l-frame is assigned this number) 
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XID_Count 


(0, 1,...,N2) 


XID_C_Data 


char [25] 


XID_C_PBit 


(0,1) 


XID_C_State 


(idle, send, wait) 


XID_R_FBit 


(0,1) 


XID_R_State 


(idle, send) 



to count the transmissions of XID commands 

data to be sent in the next XID command PDU 

value of the P-Bit used in the next XID command PDU 

if (.._State = send) the XID command PDU has to be sent 

if (.._State = wait) the RLP entity waits for the next XID response 

value of the P-Bit used in the next XID response PDU 

if (.._State = send) the XID response PDU has to be sent 



£75/ 



(GSM 04.22 version 6.2.0 Release 1997) 



31 



ETSI TS 100 946 V6.2.0 (2000-01) 



A.2 List of RLP entity events 



The interface is indicated by l:lower, u:upper and m:management. From the formal definition point of view this 
distinction of course is unnecessary. 



event# name 



semantic 



interface 



1 


Attach_Req 


2 


Connind 


3 


Conn_Conf 


4 


Conn_Conf_Neg 


5 


ConnReq 


6 


ConnResp 


7 


Conn_Resp_Neg 


8 


Data_lnd(Data) 


9 


Data_Req(Data) 


10 


DetachReq 


11 


Disc_lnd 


12 


Disc Req 


13 


DISC(P) 


14 


DM(F) 


15 


Error_lnd 


16 


LL Data Req 


17 


LL Data Ind 


18 


NULL 


19 


Ready_lnd 


20 


Reset_Conf 


21 


Reset_lnd 


22 


Reset_Req 


23 


Reset Resp 


24 


RR l(C, P F, NR, NS, Data) 


25 


RNR l(C, P F, NR, NS, Data) 


26 


REJ l(C, P F, NR, NS, Data) 


27 


SREJ l(C, P F, NR, NS, Data) 


28 


RR(C, P F, NR) 


29 


RNR(C, P F, NR) 


30 


REJ(C, P F, NR) 


31 


SREJ(C, P F, NR) 


32 


SABM(P) 


33 


UA(F) 


34 


Ul Req(Data) 


35 


UI(C, P F, Data) 


36 


T 


37 


Test_Conf(Data) 


38 


Test Conf Neg{Data) 


39 


T RCVR 


40 


T RCVS(n) 


41 


T TEST 


42 


T XID 


43 


Test Req (Data) 


44 


TEST(C, P_F, Data) 


45 


XID Req(Data) 


46 


XID Ind(Data) 


47 


XID(C, P F, Data) 



Switch to "ADIVI and Attached" 

Connect indication 

Connect confirm 

Connect confirm negative 

Connect request 

Connect response 

Connect response negative 

Data transfer indication (user data in Data) 

Data transfer request (user data in Data) 

Switch to "ADIVI and Detached" 

Disconnection indication 

Disconnect request 

PDU DISC received (P-bit in P) 

PDU DM received (F-bit in F) 

Error Indication 

Data request to lower layer 

Data indication from lower layer 

PDU NULL received 

Indication that a new PDU may be sent 

Reset confirm 

Reset indication 

Reset request 

Reset response 

l-frame RR received 

l-frame RNR received 

l-frame REJ received 

l-frame SREJ received 

S-frame RR received 

S-frame RNR received 

S-frame REJ received 

S-frame SREJ received 

PDU SABIVI received 

PDU UA received (F-bit in F) 

Unnumbered Information transfer request 

Ul PDU received 

Timeout (Timer of the sender expired) 

Test confirm (received data in Data) 

Test confirm negative (received data in Data) 

Timeout (Timer of the receiver for REJ expired) 

Timeout (Timer of the receiver for SREJ expired) 

Timeout (Test timer expired) 

Timeout (Xid timer expired) 

Test request (Test data in Data) 

TEST command/response PDU received 

(C/R-bit in C, P/F-bit in P_F, Data in Data) 

Exchange ID request 

Exchange ID indication 

XID command/response PDU received 



m 
u 
u 
u 
u 
u 
u 
u 
u 
m 
u 
u 

I 

I 
u 

I 

I 

I 

m 
u 
u 
u 
u 



u 
I 

m 
u 
u 
m 
m 
m 
m 
m 
I 

m 
m 
I 
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System RLP - Overview 



RLP User 



UserReq/Resp 

'ConnReq, 
ConnResp, 
Conn_Resp_Neg, 
Data_Req, 
Disc_Req, 
Reset_Req, 
Reset_Resp, 
UI_Req 



\/ 



Userjnd/Conf 

''Connjnd, 
ConnConf, 
ConnConfNeg, 
Datajnd, 
Disc_lnd, 
Resetjnd, 
Reset_Conf, 
Ul Ind 



RLP_Entity 



Send_queue 
[LL_Data_Req] 



\/ 



ManagerRequests 

fAttach_Req, 
DetachReq, 
Readyjnd, 
Test_Req, 
Xid_Req 



Manager! ndications 

'Errorind, 
Test_Conf, 
Test_Conf_Neg, 
Xid Ind 



RLP_Manager 



y. Receive_queue 
[LL_Data_lnd] 



LowerLayerEntity 



0422AF01. DRW 93-03-01 



Figure A.I 
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RLP_Entity 

// RLP process structure 

UserRequests 



Conn_Req, 
Conn_Resp, 
Conn_Resp_Neg, 
Data_Req, 
Disc_Req, 
Reset_Req, 
Reset_Resp, 
LULReq 



User Indications 



Connjnd, 
Conn_Conf, 
Con_Conf_Neg, 
Datajnd, 
Discjnd, 
Resetjnd, 
Reset_Conf, 
LUI Ind 



RLP Kernel 



// RLP protocol handling 



ManagerRequests 



Attach_Req, 
Detach_Req: 
Readyjnd, 
Test_Req, 
D(id_Req 



Managerjndications 





/ 


\ 


PDU_out_queue 




PDU_in_q 


■ SABM, ■ 








SABM," 


DISC, 








DISC, 


UA, 








UA, 


DM, 








DM, 


RR, 








RR, 


RNR, 








RNR, 


REJ, 








REJ, 


SREJ, 








SREJ, 


RR 1, 








RR 1, 


RNR 1, 








RNR 1, 


REJ 1, 








REJ 1, 


SREJ 1, 








SREJ 1, 


Ul, 








Ul, 


XID, 


/ \ 


XID, 


TEST, 


X \ 


TEST 


NULL 


1 1 




^ 




1 



Errorjnd, 
Test_Gonf, 
Test_Gonf_Neg 
l/idjnd 



X / \ 

Send PDU [Receive PDU 



// CRC calculation 



// CRC check and 
// PDU syntax check 



Send_queue 

[ LL_Data_Reql 



/ \ 



"TT" 



Receive_queue 

[ LL_Data_lndi 
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Figure A.2 
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r start J 







DM State := idle; 
DM_FBit := 0; 
Poll_xchg := idle; 



/* 

RLP entity - state - ADIVI and Detached 

This is the initial state after power on. 

As long as the RLP entity is "Detached", DISC(P) and/or SABIVI 
at the lower interface is acted upon by sending DI\/I(P) or Dl\/I(1 ). 
Any other stimulus at the lower interface is ignored. 

This state can be exited only with AttachReq. 




CD 



0422AF03.DRW 93-02-26 



Figure A.3 
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1 

ADM and Attached 



1 



Conn_Req 



SABM_State 
:= send; 



SABM_Count 
:=0; 



CD 



0422AF04.DRW 93-02-25 



RLP entity - state 1 - ADM and Attached 

The RLP entity is ready to establish a connection, either by initiating the 
connection itself (Conn_Req) or by responding to an incomming connection 
request (SABM). 

Upon receiving a DISC PDU, the sending of the UA response is initiated. 



SABM 



< 



^ DISC(P) ^ 



Conn Ind 



CD 



UA_State 
:= send; 



UA_FBit := P; 



CD 




CD 



Figure A.4 
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RLP entity - state 2 - Pending connect request 

Send (up to N2 repetitions) SABIVI and wait for the corresponding 
DA with FBit = 1 . 

The (sub)state is controlled by the variable SABM_State 
(values idle, send, wait) and SABM_Count (values 0, 1, ..., N2). 

This state may be exited with a Disconnect Request (see figure 14). 



see next page 




SABM_Count := 
SABM Count + 1 ; 



Poll_xchg := wait; 



Set(...,T); 



^ 
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Figure A.5 
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RLP entity - state 2 - Pending connect request 

Tills figure allowes up to N2 repetitions of SABIVI and 
describes tlie disconnect and tlie SABIVI contention case. 
*/ 



from previous page 


.■••• 2 ■•-. 

Pending Conn_Req 














^ 
















^ < 




DISC(P) /^ 


SABM / 


















PolLxchg := idle; 




Reset(T) 




Reset(T) 






















^/^^^>N2/'~\ 


^ Disc_lnd 


4 


C ConnConf 




















UA State := send; 
UA FBit := P; 




UA State := send; 
UA_FBit:=1; 




SABM_State 
:= send; 




1 










CD 


Init link vars 








d 

0422AF06.DRW 93-02-25 


b 


c^ 



Figure A.6 
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RLP entity - state 3 - pending Connect indication 

After having received SABIVI, tine RLP entity is waiting for the Connect 
response. 

The upper layer entity may respond with Conn_Resp or Disc_Req. It is 
assumed that the upper layer entity does not delay the response more 
than T2 msecs. 

The Disconnect request exit is described on a following page (see figure 14). 

7 



1 



Conn_Resp 



UA_State := send; 



UA FBit :=1; 



Init link vars 




DISC(P) 



<i 



I 



isc Ind 



d^ 



UA State := send; 



CD CD CD 



UA_FBit := P; 



C±) 



0422AF07.DRW 94-09-15 



Figure A.7 
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/* 

RLP entity - state 4 - Connection establislied 

Tliis is tine data transfer state. Ttie user entity may transmit data by 
fireing Data_Requests. However, lie is allowed to do so only if tliere 
are idle sender slots. 




1 



Data_Req 
(data) 



S[VD].State := send; 
S[VD].Data := data; 



VD := VD + 1 
modulo M; 



& 



0422AF08.DRW 93-09-10 



The data stored in the send slots will be transmitted at the next possible 
opportunity. 

This state may be exited by a Disconnect Request (see Figure 14). 

7 



Ready_lnd 



I 



Send TXU 




<z:) 



Send Data 



Q 



■ see next page 



DISC(P) 



I 



Reset(T); 



Reset(T_RCVR) 
Reset all T RCVS's 



< 



Disc Ind 



UA_State := send; 
UA_FBit := P; 



CD 



Figure A.8 
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/* 

RLP entity - state 4 - Connection established 

This dagram describes RESET and the Timeout-handling. 

A timeout leads to error recovery by polling. This is controlled by 
the Poll State variable. The Poll State transitions are: 



• 4 - 

Connection 
established 



from previous p 



> 



1 



Reset_Req 



Reset(T); 



idle -> send <-> wait -> idle 



Zero up to N2 transitions wait->send may occur. 

7 



see next page 



SABM 



\^ T_RCVR \^ 



Reset(T); 



REJ_State 
:= idle ; 



Reset(T_RCVR) 
Reset all T RCVS's 



Reset(T_RCVR) 
Reset all T RCVS's 



SABM_State 

:=send; 
SABM_Count 
0: 




< 



Reset Ind 



ct> 



Reset SREJ-ted 
slots to idle; 



CD 




PolLState 

:=send; 

PolLCount 




PolLState 

:= send; 

PolLCount := 

Poll Count+1; 



^ 
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RLP entity - state 4 - Connection established 

Tliis diagram describes tine liandling of l-frames and S-frames 
(PDUs RR, RNR, REJ, SREJ and RRJ, RNRJ, REJJ, SREJ_ 



If the frame contains user information, this is handled by the l-Handler. 
The supervisory information is handled by the S-handler. 



Connection J A frame with an unsolicited F-bit is ignored, 
established ..■■' */ 



from previous page 




/* sets returncode if the 
frame fias to be ignored 7 



S handler 



CD 



CD 
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RLP entity - state 5 - Disconnect initiated 

Ttiis state is exited only after a valid response is received 
or after N2 timeouts. 

*/ 



Readyjnd 



Send TXU 



^ UA(F) ^ DM(F) -^ 



Mcr- cw„^^ yss r ^ .••(DISC PBit = 1) ■•. 
)ISC_State"S 1 nU ) j and i 

•.(Poll_xchg = wait) .• 




DISC(P) 



© 



Reset(T); 




UA_State 

:= send; 

UA_FBit 

:=P; 



Poll_xchg := wait; 
1 



DISC_State := 

wait; 
DISC_Count := 
DISC Count + 1; 
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Poll_xchg := idle; 




DISC_State 
:= send; 




Figure A.11 
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RLP entity - state 6 - pending Reset Request 

Send (up to N2 repetitions) SABIVI and wait for the responding UA with FBit=1 . 

The substate is controlled by the variable SABM_State (values idle, send, wait) 
and SABM_Count (values 0..N2). 

This state may be exited with a Disconnect Request (see Figure 14). 

V 



Ready_lnd 




DISC(P)' 



Reset(T); 



^ SABM ^ T ^ 



Reset(T); 



Disc Ind 



SABM 



Poll_xchg 
:= idle; 



^Reset_Conf <SABM_Counp>—( error j 



UA State := 




UA State := 


send; 




send 


UA FBit := P 




UA FBit := 1 



CD 



SABM_State 
:=send; 



Init link vars 



Init link vars 



SABM_State 
:= wait; 



Q 



& Ct) 



CD 



SABM_Count := 
SABM Count + 1 



Poll_xchg := wait; 



Set(..., T); 
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RLP entity - state 7 - pending Reset Indication 

After having received SABIVl and tiaving indicated Reset, ttie RLP 
entity is waiting for thie Reset_Response. 




1 



Reset_Resp 



UA_State := 
send; 
UA FBit:=1; 



Init linl< vars 



CD 



The upper layer entity may respond with Reset_Resp or Disc_Req. 
It is assumed, that the upper layer entity does not delay the response 
more than T2 msecs. 

The Disconnect Request is described on a following page 
(see Figure 14). 

7 




DISC(P) 



<^ 



I 



isc Ind 



UA_State := 
send; 
UA FBit:=P; 



& 
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This is tlie error liandling 
wlien tliere is no action 
from tlie remote end 
after N2 repetitions. 
Tlie error liandling 
and tlie state transition 
depends on tlie situation 
e.g. ADIVI in case of DISC 
V 



/* 

Detacli Request 

Detach is allowed at 
any time. 

The Detach Request 
is used to reset the RLP 
entity to state 0, e.g. if 
the physical connection 
is lost. 
7 



/* 

Disconnect Request 

Disconnect is used to release a connection. 

The actions to be executed in these cases are: 
reset the timer, activate sending of the DISC PDU. 

The P-bit in the DISC command is set to 
one or zero, depending on the Poll_xchg state. 

7 
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CX> 




1 



Disc_Req 



Reset(T); 



DISC_State := 

send; 
DISC Count := 0; 




Poll_xchg 



:idle 



DISC_PBit:=1; 



else 



DISC PBit:=0; 



Ct> CD 



Figure A.14 
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Ul handling (UI_Req, Ul) 

UI_Requests are controlled using the state variable UI_State. The values 
(state transitions) are: idle -> send -> idle 

It is assumed that the upper layer entity issues an UI_Req only if the RLP 
entity's UI_State is idle. The Ul data is stored in the variable UI_Data. 

The UI_PDU is generated at the next possible opportunity, i.e. after 
the higher priviledged PDUs (TEST PDUs, XID PDUs, if any) have been 
transmitted. 
7 




(except 0) 



1 



UI_Req 
(data) 



Ul Data := data; 



ULState := send; 



ULPBit := 0; 



& 



Ul 
(C,P,data) 



< 



I 



Ul_lnd(data) 



CZ) 



/* 

Ul frames with P-Bit set to 1 
will not be genereted. 
(implementation decision). 

7 
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/* 

XID handling (XID_Req, XID) 

XID requests are controlled using the state variable XID_C_State and 
XID_R_State. The state transitions being used are: 



idle -> send -> wait -> idle 



The XID data is stored in the variable XID C Data 



XID_Count 
:=0; 




XID_C_PBit 
:=1; 



XID_Count := 
XID Count + 1; 



XID_C_Data 
:= data; 



XID_C_State 
:= idle; 



CZ> 



/* 

The action on a received XID command PDU depends on the state variable XID_C_State. In the contation case the 

XID Command is sent again after a certain delay, depending on the 'location' of the RLP entity. 

The XID command/response PDU is sent at the earliest possible opportunity, next after a possible pending TEST PDU 
(see procedure SEND_TXU) The value of the timer should be T1 ms in the Mobile Station, it should be twice this value 
in the Interworking Unit. This scheme is used to avoid repetinion of contentions. 

7 
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r 

TEST handling (TEST_Req, TEST_PDU, TESTJmeout) 
7 




(except 0) 



1 



TEST_Req 
(data) 



TEST 

(C,P_F,data) 



I 



TEST_C_State 
:= send; 



TEST Count := C 




TEST_R_State 
:= send; 



TEST C PBit := ' 



TEST_C_Data 
:= data; 
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TEST_R_FBit 
:= P_F; 



TEST_R_Data 
:= data; 




else 



else 



= TEST C PBit 



Reset(T_TEST); 




TEST_C_State 
:=send; 



G> 



CD 




<TEST_Conf_neg 
(no_response) 



TEST_Count := 
TEST Count-i-1 



Poll_xchg:=idle; 



TEST_C_State 
:= idle; 



Q Q 




TEST C Data else 



TEST_Conf_neg 
(data_error) 



TEST C State := TEST C State 



idle; 



idle; 



^^ 



Figure A.17 
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Process Receive PDU 



Receive a block, test CRC and indicate PDU to 
RLP Kernel if and only if CRC is ok, otherwise 
ignore the invalid block. 

7 
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/* 

Receive a block, test CRC and indicate PDU to RLP Kernel 

7 



< 



RR 



RR_I(C,P, 
NR,NS,Data) 



< 



RR 



RR(C,P,NR) 



TEST 



RNR I 



RNR_I(C,P, 
NR,NS,Data) 



< 



REJ I 



REJ_I(C,P, 
NR,NS,Data) 



RNR 



RNR(C,P,NR) 



REJ 



REJ(C,P,NR) 



\ (C,P_F, Data) \ (C, 



XID 



XID 
,P_F, Data) 



Ul 



UI(C,P_F, Data) 



SREJ I 



SREJ_I(C,P, 
NR,NS,Data) 



o o o o 



SREJ 



SREJ(C,P,NR) 



O O O O 



else 



/* ignore 
block 7 



o o o o 
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Process Send PDU 




/* 

Generate CRC and forward complete PDU 
to lower layer to send it. 

*/ 



\ SABM \ DISC(P) \ UA(F) \ 



DM(F) 







\rr_i(c,p, I \rnr_i(c,p, I \REJ_I(C,P, I "^ 
y^NR,NS,Data) y^NR,NS,Data) y^ NR,NS,Data) /I 



.SREJ_I(C,P, 
^NR,NS,Data) 









\rR(C,P,NR) \rNR(C,P,NR) \rEJ(C,P,NR) Nb 




5REJ(C,P,NR) 




1 



TEST 
'C,P_F, Data 




. XID 
fC,P_F, Data 




fC,P_F, Data 





calculate CRC 



I 



NULL 




LL_Data_Req 
(block) 



> 
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Initialise link variables - This procedure is called if the linl< is established or the linl< is reset. 

7 



( lnit_link_vars j ( lnit_slots j 



Ackn State := idle; 



PolLState := idle; 
Poll_Count:= 0; 



Poll_xchg := idle; 
REJ State := idle; 



SABM_State := idle; 
DISC State := idle; 



RRReady := true; 



VA:=0; 
VR:=0; 



VS:=0; 
VD:=0; 



Init slots 




n:=0; 



R[n].state := idle; 



S[n].state := idle; 



n := n + 1; 




There are M data receiver slots and M data sender slots (M <= 62). 

The receiver states are: idle, rcvd, send, wait. 

State = idle means: nothing received (with this number). 

State = rcvd means: data received, to be delivered and acknowledged only if in sequence. 

If delivered, the state becomes idle again. 
State = send means: pending retransmission request for this block. 
State = wait means : waiting for receiption of requested block. 



The sender slot states are: 



idle, send, wait. 



State = idle means: nothing to do, slot may be used (again). 
State = send means: send data at the next possible opportunity. 
State = wait means: wait for the acknowledgement 

7 
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/* 

Handling the I part of the received frame 

(PDUisRR, RNR, REJorSREJ). 

The P-bit must not be set in l-frames. 

The sequence number NS must be within 
the current window. 

The returncode informs, if the frame has 
been regarded as improper. 

7 



/* ignore 
improper 
frame */ 




<N^witiiinN ^yes 
window ?^^ 



returncode := 1 ; 



/* ignore 
improper 
frame */ 
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else 



R[VR].state 
:= rcvd; 



^is SREJs. 



no 



R[VR].data 
:= Data; 



yse^? 



^RfNSl.State^ no _^s REJ^ 
"^used ?^ 



no 



Deliver all 

in-sequence 

l-frames 



= wait ? 
[yes 



Reset 
T_RCVS[NS]; 









R[NS 


.state 


REJ State 
:= idle; 




:= rcvd; | 














R[NS].data 
:= Data; 


ACKN State 




:=S6 


nd; 










Mark missing 
l-frames to 
be SREJted 






else 



REJ_State 
:= send; 



returncode := 1 ; 




/* ignore out- 

of-sequence 

I -frame */ 




Figure A.22 
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Deliver all in-sequence l-frames 

Indicate all already received in-sequence 
information blocl<s. Ttiere may be more 
than one blocl< wtiicti lias to be indicated 
due to successful selective recovery. 

7 



/* 

marl< all missing l-frames 

All missing l-frames "between" 
VR an NS fiave to be marl<ed 
if their state is idle. 

7 



(Deliver all in- A 
sequence l-frames/ 
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(Mark missing ^ 
IJrames y 



n:=VR; 



= idle 



<^nj. 


Statep»" 








R[VR].state 
:=send; 










\ 






n :=n-i-1 
modulo M; 






Figure A.23 
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Handling the S part of the received frame 

(PDU is RR, RNR, REJ or SREJ or l-frames piggy- 

baci<ed with supervisory information).. 

The sequence number NR must be within the set 
of not yet aci<nowledged l-frames or it must be the 
next possible frame number. This condition is already 
checked, before the S_handler is called (see Figure 10). 




SREJ 
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Advance the lower 
window edge 

*/ 



/* 

Set the sender slot 

states to send again 

*/ 



(advance VA ^ 
uptoNR-1 J 





S[VA].State 
:= idle; 



VA := VA+1 
modulo IVI; 



(decrease VS ^ 
down to NR y 




VS := VS-1 
modulo IVI; 



S[VS].State 
:= send; 
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Send_Data is called, if there is a send opportunity. 
It decides upon RR, RNR, REJ or SREJ, however first 
it is checked, if an UA Response must be send. 



Send 

RR or RR_I 

Resp 




1 Send f 
RNRorRNRJ 
I Resp I 





get slot 
number n 



Send RR or RRJ Response is described in Figure 27, 

Send RNR or RNR_I Response also is described in Figure 27, 

Send REJ or REJJ Command can be found in Figure 29 




1 Send r 
SREJorSREJJ 
I Cmd(n) I 




Send 

RR or RR_I 

Cmd 




I Send I 
RNRorRNRJ 
I Cmd I 
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Send SREJ or SREJ_I Command (n) is described in Figure 30, 

Send RR or RR_I Command is described in Figure 28, 

Send RNR or RNRJ Command also can be found in Figure 28. 

7 
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Send XX or XX_I response PDU with F-Bit set to one. 

XX may be RR or RNR. 

*/ 
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(Send XX or ^ 
XX_I Cmd J 




wait 



else 



XX 

(1,1,VR) 



ACKN_State 
:= idle; 



PolLCount := 
Poll Count+1; 



PolLState 
:= wait; 



Poll_xchg 
:= wait; 



Set(..., T) 




Send XX or XXJ Command PDU. 

XXmaybeRRorRNR. 

Supervisory frames may be candidates for DTX. 




ACKN_State 
:= idle; 



S[VS].State 
:= wait; 



VS := VS + 1 
modulo IVI; 



Set(..., T) 




else 



Supervisory only frames 
are candidates for DTX. 

As shown here DTX may 
be indicated for the first 
redundant S-frame. Other 
strategies are possible. 

7 




XX 

(0,1, VR) 



ACKN_State 
:= idle; 



DTX_SF 
:=XX; 



DTX_VR 
:=VR; 
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(Send REJ or ^ 
REJ_I Cmd J 




wait 



else 



REJ 
(1,1,VR) 



ACKN_State 
:= idle; 



REJ_State 
:= wait; 



I 

Set(...,T_RCVR) 



PolLCount := 
Poll Count+1; 



PolLState 
:= wait; 



PolLxctig 
:= wait; 



Set(..., T) 




Send REJ or REJ_I Command PDU. 

7 



<D 




<KemoTe^ 
receiver ^^ 
ready ?^ 

ryes 



— fT 
(1,0,VR,VS, 
SfVSIData) 



ACKN_State 
:= idle; 



REJ_State 
:= wait; 



1 

Set(...,T_RCVR) 

I 



S[VS].State 
:= wait; 



VS := VS + 1 
modulo IVI; 



Set(..., T) 




REJ_State 
:= wait; 



1 

Set(...,T_RCVR) 
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(Send SREJ or N 
SREJJ Cmd(n)y 




Send SREJ or SREJJ Command PDU. 

7 



= wait 



else 



R[n].State 
:= wait; 



Set(...,T_RCVS[n]) 



PolLCount := 
Poll_Count+1; 



PolLState 
:= wait; 



PolLxctig 
:= wait; 



Set(..., T) 
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receiver ^^ 

lyes 
SRbJ_l \ 
(1,0,n,VS, 
S[VS1.Data). 



no 





1 






R[n].State 
:= wait;; 






1 




Set(...,T_RCVS[n]) 










S[VS].State 
:= wait; 






1 






VS := VS -F 1 
modulo IVI; 






1 






Set(..., T) 










REJ \ 



SREJ 
(1 



R[n].State 
:= wait; 



Set(...,T_RCVS[n]) 




Figure A.30 
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Ul 
(1,0, ULData) 



> 



ULState 
:= idle; 



returncode := 1 ; 
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/* 

Send a pending TEST, XID or Ul PDU 
(or do nothing, if no PDU is pending). 

The returncode indicates if something 
has been sent. 



TC 



@ 



TEST 

(0, TEST_R_FBit, 

TEST_R_Data) 



I 



TEST_R_State 
:= idle; 



returncode := 1 ; 





XID 
(0,1, XID 



R_Data]/ 



XID_R_State 
:= idle; 



returncode := 1 ; 




TEgf C_reit=1 yes 
<^ and >-— (txUI 
Poll xchg=wait 




TEST 

(1,TEST_C_PBit, 

TEST_C_Data) 




C_PBit^>- 


1 




PolLxchg 
:= wait; 


i 


1 




XID 
(1,1,XID_C_Data) 



> 



XID_C_State 
:= wait; 



Set(...,T_XID); 



Poll_xchg := wait; 



returncode := 1 ; 




Figure A.31 
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Annex B (Informative): 
Change history 



SMG# SPEC CR PHA VERS 


NEW_VER 


SUBJECT 


sl6 04.22 A004 ^ 






5.0.0 


Data Compression 


sl6 


04.22 


A005 






5.0.0 


DM clarification and editorial changes 


sl6 


04.22 


A007 






5.0.0 


RLP SDLs 


s21 


04.22 


A009 


2+ 


5.0.1 


5.1.0 


Support of 14.4 kbit/s (Radio interface related) 


s21 


04.22 


A006 


2+ 


5.0.1 


5.1.0 


RLP extension for HSCSD 


s22 


04.22 


A008 


2+ 


5.1.0 


5.2.0 


14.4 Icbit/s corrections and alignments 


s22 


04.22 


AGIO 


2+ 


5.1.0 


5.2.0 


Modification of RLP for HSCSD 


s23 


04.22 


AOll 


R96 


5.2.0 


5.3.0 


Corrections for 14.4 kbit/s 


s23 


04.22 


A012 


R96 


5.2.0 


5.3.0 


HSCSD 


s25 


04.22 


A013 


R96 


5.3.0 


5.4.0 


Improvements requested by SMG7 


s25 


04.22 


A015 R96 5.3.0 


5.4.0 


RLP restart Wl HSCSD 


s26 


04.22 


A016 


R97 


5.4.0 


6.0.0 


Editorial Corrections 


s27 


04.22 


A017 


R97 


6.0.0 


6.1.0 


Use of Poll/Final-Bit for REMAP 


s27 


04.22 


A018 


R97 


6.0.0 


6.1.0 


No XID during REMAP 


s27 


04.22 


A019 


R97 


6.0.0 


6.1.0 


Applicability of default values for REMAP procedure 


TSG#6 


04.22 


A025rl 


R97 


6.1.0 


6.2.0 


Correction to REMAP procedure in RLP 
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